From 1367af1cca57e051d6f7b723056a422cc9d4fd46 Mon Sep 17 00:00:00 2001 From: Juergen Gross Date: Mon, 18 Jan 2016 09:04:02 +0100 Subject: [PATCH] xenstore: write xenstore domain data to xenstore After starting the xenstore domain write the basic data (domid, name and memory values) to the xenstore. This makes the domain appear correctly in xl list. Create a stub json object in order to make e.g. xl list -l happy. Add a new option to init-xenstore-domain to be able to specify the domain's name. Signed-off-by: Juergen Gross Acked-by: Ian Campbell --- tools/helpers/Makefile | 6 ++-- tools/helpers/init-xenstore-domain.c | 44 +++++++++++++++++++++++++--- 2 files changed, 44 insertions(+), 6 deletions(-) diff --git a/tools/helpers/Makefile b/tools/helpers/Makefile index 0325ba2b45..a05a368566 100644 --- a/tools/helpers/Makefile +++ b/tools/helpers/Makefile @@ -15,10 +15,12 @@ $(XEN_INIT_DOM0_OBJS): CFLAGS += $(CFLAGS_libxentoollog) $(XEN_INIT_DOM0_OBJS): CFLAGS += $(CFLAGS_libxenstore) $(XEN_INIT_DOM0_OBJS): CFLAGS += $(CFLAGS_libxenlight) -INIT_XENSTORE_DOMAIN_OBJS = init-xenstore-domain.o +INIT_XENSTORE_DOMAIN_OBJS = init-xenstore-domain.o init-dom-json.o +$(INIT_XENSTORE_DOMAIN_OBJS): CFLAGS += $(CFLAGS_libxentoollog) $(INIT_XENSTORE_DOMAIN_OBJS): CFLAGS += $(CFLAGS_libxenguest) $(INIT_XENSTORE_DOMAIN_OBJS): CFLAGS += $(CFLAGS_libxenctrl) $(INIT_XENSTORE_DOMAIN_OBJS): CFLAGS += $(CFLAGS_libxenstore) +$(INIT_XENSTORE_DOMAIN_OBJS): CFLAGS += $(CFLAGS_libxenlight) .PHONY: all all: $(PROGS) @@ -27,7 +29,7 @@ xen-init-dom0: $(XEN_INIT_DOM0_OBJS) $(CC) $(LDFLAGS) -o $@ $(XEN_INIT_DOM0_OBJS) $(LDLIBS_libxentoollog) $(LDLIBS_libxenstore) $(LDLIBS_libxenlight) $(APPEND_LDFLAGS) init-xenstore-domain: $(INIT_XENSTORE_DOMAIN_OBJS) - $(CC) $(LDFLAGS) -o $@ $(INIT_XENSTORE_DOMAIN_OBJS) $(LDLIBS_libxenstore) $(LDLIBS_libxenctrl) $(LDLIBS_libxenguest) $(APPEND_LDFLAGS) + $(CC) $(LDFLAGS) -o $@ $(INIT_XENSTORE_DOMAIN_OBJS) $(LDLIBS_libxentoollog) $(LDLIBS_libxenstore) $(LDLIBS_libxenctrl) $(LDLIBS_libxenguest) $(LDLIBS_libxenlight) $(APPEND_LDFLAGS) .PHONY: install install: all diff --git a/tools/helpers/init-xenstore-domain.c b/tools/helpers/init-xenstore-domain.c index 238007b254..5c5af2dc78 100644 --- a/tools/helpers/init-xenstore-domain.c +++ b/tools/helpers/init-xenstore-domain.c @@ -13,11 +13,14 @@ #include #include +#include "init-dom-json.h" + static uint32_t domid = ~0; static char *kernel; static char *ramdisk; static char *flask; static char *param; +static char *name = "Xenstore"; static int memory; static struct option options[] = { @@ -26,6 +29,7 @@ static struct option options[] = { { "flask", 1, NULL, 'f' }, { "ramdisk", 1, NULL, 'r' }, { "param", 1, NULL, 'p' }, + { "name", 1, NULL, 'n' }, { NULL, 0, NULL, 0 } }; @@ -42,7 +46,8 @@ static void usage(void) " --memory size of the domain in MB, mandatory\n" " --flask optional flask label of the domain\n" " --ramdisk optional ramdisk file for the domain\n" -" --param optional additional parameters for the domain\n"); +" --param optional additional parameters for the domain\n" +" --name name of the domain (default: Xenstore)\n"); } static int build(xc_interface *xch) @@ -216,6 +221,20 @@ static int check_domain(xc_interface *xch) return 0; } +static void do_xs_write(struct xs_handle *xsh, char *path, char *val) +{ + if ( !xs_write(xsh, XBT_NULL, path, val, strlen(val)) ) + fprintf(stderr, "writing %s to xenstore failed.\n", path); +} + +static void do_xs_write_dom(struct xs_handle *xsh, char *path, char *val) +{ + char full_path[64]; + + snprintf(full_path, 64, "/local/domain/%d/%s", domid, path); + do_xs_write(xsh, full_path, val); +} + int main(int argc, char** argv) { int opt; @@ -243,6 +262,9 @@ int main(int argc, char** argv) case 'p': param = optarg; break; + case 'n': + name = optarg; + break; default: usage(); return 2; @@ -274,10 +296,24 @@ int main(int argc, char** argv) if ( rv ) return 1; + rv = gen_stub_json_config(domid); + if ( rv ) + return 3; + xsh = xs_open(0); - rv = snprintf(buf, 16, "%d", domid); - xs_write(xsh, XBT_NULL, "/tool/xenstored/domid", buf, rv); - xs_daemon_close(xsh); + if ( !xsh ) + { + fprintf(stderr, "xs_open() failed.\n"); + return 3; + } + snprintf(buf, 16, "%d", domid); + do_xs_write(xsh, "/tool/xenstored/domid", buf); + do_xs_write_dom(xsh, "domid", buf); + do_xs_write_dom(xsh, "name", name); + snprintf(buf, 16, "%d", memory * 1024); + do_xs_write_dom(xsh, "memory/target", buf); + do_xs_write_dom(xsh, "memory/static-max", buf); + xs_close(xsh); fd = creat("/var/run/xenstored.pid", 0666); if ( fd < 0 ) -- 2.30.2